草庐IT

MongoDB $project : $filter sub-array

全部标签

mongodb - 构建包含字符串和正则表达式模式的 $in 数组

我有一个Mongo集合,集合中的每个文档都有一个sources数组属性。对此属性的搜索可以是精确匹配和正则表达式的组合。例如,当使用Mongoshell时,下面的查询搜索source='gasvalves'OR'hose'包含在源项中的文档。这和我预期的一样有效db.notice.find({sources:{$in:[/\bhose/i,'gasvalves']}})mgo中的事情变得有点棘手。因为$in数组中的某些项目可以是正则表达式,而其他项目是字符串-我想进行查询的唯一方法是使用$or:varregEx[]bson.RegExvarmatches[]string//dostuf

mongodb - mongo-go-driver 投影数组长度

我正在尝试对文档数组中的元素数量进行预测。options.SetProjection(bson.M{"foo":true,"nrOfBars":bson.M{"$size":"$bars"},})bars是数组的字段名。尽管此查询始终返回0而不是数组长度。如何使用新的mongo-go-driver正确查询数组的长度? 最佳答案 您正在尝试使用聚合运算符作为投影文档的一部分。projectiondocument用于简单查询以仅返回某些字段。您要使用的是aggregationpipeline中的$project阶段。这与简单的投影文档不

mongodb - 为集合中的过期数据设置 TTL

是否有使用officialmongodriver按键配置数据自删除的正确方法??我在Mongo-driver模块中找到的唯一方法是ExpireAfterSeconds,但我不确定如何正确使用它。这是repository与目前准备好的东西。 最佳答案 你需要在n秒后需要删除的字段上创建一个ttl索引。在下面的代码片段中,创建了一个可以设置ttl的expirationTime字段。在记录中设置的expirationTime60秒后,记录将被删除。以下是创建TTL索引的代码:varttl*int32*ttl=60keys:=bsonx.D

mongodb - UUID 作为 _id 错误 - 不能将数组用于 _id

我正在尝试为MongoDB中的_id字段使用UUID。我有一个包装器结构来保存我的记录,如下所示:typemongoWrapperstruct{IDuuid.UUID`bson:"_id"json:"_id"`Paymentstorage.Payment`bson:"payment"json:"payment"`}这是我围绕MongoDB驱动程序包中的InsertOne函数编写的代码:func(s*Storage)Create(newPaymentstorage.Payment)(uuid.UUID,error){mongoInsert:=wrap(newPayment)c:=s.cl

go - 如何在 computeService.Zones.List(project) Google Cloud Platform API 中添加过滤器

我正在尝试在GoogleCloudPlatformAPI中过滤区域列表但我无法在Google中找到任何说明在API中放置过滤器的文档:req:=computeService.Zones.List(project)上面的代码行将列出GoogleCloudCompute中的区域在命令行中我们可以做同样的事情gcloudcomputezoneslist--filter="name:us-"谢谢,席德 最佳答案 它会在以下情况下帮助某人:req:=computeService.Zones.List("ProjectName")iferr:=

arrays - 有效地保存最后 N 个推送项目的集合

给定:具有已知容量的slice容量和片数都很大,会用到15MB左右的内存,不想浪费内存,想保持最小内存。slice将通过删除第一个元素并将新元素添加到slice的末尾来更新。b=append(b[1:],n)会增加容量为了转移和分配自己,我写了funcshiftAndPut(a[]int,nint)(b[]int){b=make([]int,cap(a),cap(a))fori,v:=range(a[1:]){b[i]=v}b[len(b)-1]=nreturn}https://play.golang.org/p/7xIBh0UPp2w它保持容量不变,但需要各种计算迭代slice一次,

mongodb - 如何根据带有整数键的嵌套数组中的值查找文档?

我的查找查询如下所示:bson.M{"_id":oId,"items":bson.M{"$elemMatch":bson.M{"id":theId,"active":true}}}(其中theId是方法中的对象ID)我要做的是选择一个具有匹配id且active设置为true的文档{"_id":ObjectId("5ca0e44acb216df65405dc5f"),"items":{"0":{"id":ObjectId("5c9fbb25e86deef65491c321"),"active":true},"1":{"id":ObjectId("5c9fbb57cb216df65405d

mongodb - 为什么我的 mongodb 查询返回 0 个结果?

这是我的数据库集合:使用此go代码,我尝试获取所有参与故事或使用给定ID创建故事的用户。funcmain(){forstf.DB==nil{}collection:=stf.DB.Collection("user")ctx,cancel:=context.WithTimeout(context.Background(),30*time.Second)defercancel()id,_:=primitive.ObjectIDFromHex("5cb4dd7e29d3dca573a73d4c")fter:=bson.M{"_id":id}involvedFilter:=bson.M{"st

arrays - 从 golang 中的 redash 解码 json 原始数据

我收到redash的回复如下:{'PP_DOM':'{"DEFAULT":100}',.....................,'Myst':'["a","b","c","d"]',我想将"myst"键的值解码为golang中的列表。我是这里的新手。 最佳答案 如果你有一个未知的数据结构来探索它,你可以解码到map[string]interface{}中。然后您可能稍后想要定义一个正确映射到数据的结构。所以要开始,使用这样的东西:varjsonData=[]byte(`{"PP_DOM":{"DEFAULT":100},"Myst

mongodb - 如何从 wasm 模块连接到本地 mongodb 实例?

我正在尝试使用编译为WebAssembly的Go将一些数据存储在我的本地MongoDB实例中。问题是,我什至无法连接到它。mondog实例不会以任何方式对来自wasm模块的连接使用react。只有从wasm模块连接时才会出现此问题。以普通方式编译时相同的代码工作正常,以及来自mongoshell的连接。运行的mongod实例没有密码保护。如果重要的话,我的操作系统是Windows10。我尝试将mongodbind_ip参数从localhost更改为我机器的实际本地地址,并使用不同的浏览器(Chrome75.0.3770.80,Opera60.0.3255.109)。更改超时持续时间也无